
/*
*Pool Public Licence version 0.1 or later
*Released on 20th April 2008.
*Any voilations can be repoted at paritosh@wikiocean.net
*What is treated as voilations can be found at www.wikiocean.net/ppl1-voilations* 
******************************************************************************
* The contents of this file are subject Affero GPL v3 and later with additional conditions.
* The additional conditions are to be considered as part of the Affero GPL v3 and later.
* The additional conditions will supersede the Affero GPLv3 and later in case of conflict.
* ("License"); You may not use this file except in compliance with the License
* You may obtain a copy of the License at http://www.gnu.org/licenses/agpl.html
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
* The Initial Developer of the Original Code is Paritosh Pungaliya.
* created by Paritosh Pungaliya are Copyright (C) Paritosh Pungaliya; All Rights Reserved.
* Contributions are Copyright (C) 2001-2008 Paritosh Pungaliya.

* Objective of the additional terms (license) 
* 1) Is to extend the software freedom to freedom to work.
* 2) To ensure that knowledge is free from monopoly of agencie(s).
* 3) To avoid a situation where big corporates or investors can buy out free software groups and companies and then start milking the communities built around it.
* (this trend can be seen how the openness changes in companies that get Venture Capital funding.)
* (if you agree to this logic I invite you to our group to work together)

* Additional conditions
*  0) Source code will also include
* 	a) data dictionaries, data ontologies which are used to alter the behavior of code or to control           the features of application.
* 	b) Any code generated or derived automatically or manually from this code or logic
*  1) The revenue generated by deploying, implementing , selling services and other activities
*  	 based on this source code should be shared 100%, between the people working on it.
*  2) Capital invested should be given only fixed rate of return or linked to revenue/surplus growth for limited time.
*  3) People working on the project should always have an option to replace the capital provider in full or part with lower cost capital.
*  4) Their should not be any ownership which can be sold as a claim on future profit to be generated from the work of people working on the code.
*  5) Brand thus generated should belong to the group.
*  6) For old and new members revenue sharing should be equal for same work equivalent.
*  7) The share of revenue should be decided by bidding for work before allocation of work within the group.
*  8) Before bidding various method of measuring the work should be clearly defined and published in public domain. Any change in process should also be publised in public domain imediately.
*  9) All data related to to revenue sharing should be published as and when generated in public domain.
*  10) For group of people having size more than 10 people will have to make it open online for others to participate in bids. 
*  11) All people involved in related and sub project will be treated as a group.
*  12) Once this license is being used for a certain code then all and any other software services being provided by the group should complusorilly come under 100% revenue sharing.
*  13) Cross subsidization should not happen under this revenue share, no additional benefit should be drawn from the people, by the employing agency.
*  14) Any position or knowledge or legal structure created relating to people working on code, which adversely affects the spirit of 100% revenue share will be treated as a violation.
*  15) Revenue sharing defined.
*     a) includes direct revenue and also intangible gains like brand, and organization.
*     b) No personal judgment should be involved in judging the distribution of revenue.It has to be pre-defined formula based.
*     c)100% of revenue should be shared before expenses and recievers should have control over what expenses to incur.
*     d)For the work done in any month by contributing group member, working on any project can be given revenue share from the work done by the group, for a maximum of 18 months after that month.
*     e)Revenue should be apportioned to the month in which work is done and not when received.
*  The group fulfilling the above conditions also has to be a wiki ecosystem further defined in www.wekosystem.org or read about Wekosystem at www.wikiocean.net

*  ******************************************************************************
*/  
package integration;

//import java.sql.Connection;
import java.sql.ResultSet;
import java.util.Enumeration;
import java.util.Hashtable;
import java.util.Vector;

import pool.bean.IdBean;
import pool.bean.Master_table_Bean;
import control.RequestParameter;

import dbmanager.DBManager;
import dbmanager.GetIdName;


public class InsertMaster 
{

	/*private String integrateObject = "SugarpoolObject";
	private String tablistObj = "tablistobj";*/
	private String recentTableObject = "";
	String process = "add";
	String tableObj = "";
	String fieldTable = "table";
	String fieldTableName = "tablename";
	String fieldTablist = "tablelist";
	String fieldList = "fieldlist";
	String database = "database";
	String field = "field";
	String column = "column";
	String property_details = "property_details";
	String connObjId;
	
	DBManager dbsql;
	//DBManager integratedDB;
	//Connection conn;
	GetIdName gin ;
	Hashtable<Object, Object> fieldHash = new Hashtable<Object, Object>();
	Hashtable<Object, Object> poolHash = new Hashtable<Object, Object>();
	Hashtable<Object, Object> ModuleHash = new Hashtable<Object, Object>();
	
	Vector<Object> propertyVect = new Vector<Object>();
	
	public InsertMaster() 
	{
	}
	
	public void setDatabase(DBManager database) {
		this.dbsql = database;
		gin = new GetIdName(dbsql);
	}
	
	public void setTableObj(String tableObj) 
	{
		this.tableObj = tableObj;		
	}
	
	public void setRecentTableObject(String recentTableObject) 
	{
		this.recentTableObject = recentTableObject;
	}
	/*public QueryProcessor(String integrateObject, String tablistObj)
	{
		this.integrateObject = integrateObject;
		this.tablistObj = tablistObj;
	}*/
	
	public void generateProperty() 
	{
		generateModuleHash();
		generatePoolHash();
		/**It will fetch the value from pool hash and append the column values in field hash.*/		
		Enumeration<Object> poolIte = poolHash.keys();
		while(poolIte.hasMoreElements())
		{
			String key=null;
			try 
			{
				key = poolIte.nextElement().toString();
				if(ModuleHash.containsKey(key))
				{
					String value = poolHash.get(key).toString();
					fieldHash.put(key, value);
				}
			} catch (Exception e) {
			}
		}
	}
	
	public void generateModuleHash()
	{
		/*String integrateObjId = gin.getId(integrateObject);
		String tablistObjId = gin.getId(tablistObj);
		
		ResultSet rsObject = dbsql.getSelect("SELECT pid, pv, vt FROM property_details WHERE mid = " + integrateObjId);*/
		
		/**Setting parameters for getting connection object.**/
		//String tableObjId = gin.getId(tableObj);
		
		
		/**Setting parameters for getting field list from table name.*/
		String fieldId = gin.getId(field);
		String columnId = gin.getId(column);
		String fieldListId = gin.getId(fieldList);
		
		String query = "SELECT DISTINCT d6.id,d6.mid, d6.pid, d6.pv, d6.vt FROM " + property_details + " d3 JOIN (" + property_details + " d4 JOIN (" + property_details + " d5 JOIN " + property_details;
		query = query + " d6 ON (d6.mid = d5.pv)) ON (d5.mid = d4.pv)) ON (d3.mid = d4.mid) ";
		query = query + "WHERE d3.mid = " + tableObj + " AND ";
		query = query + "d4.pid = " + fieldListId + " AND d5.pid = " + fieldId + " AND (d6.pid = " + fieldId +" OR d6.pid = " + columnId + ") order by d6.mid, d6.pid";
		
		System.out.println(" Query : " + query);
		ResultSet rsField = dbsql.getSelect(query);
		
		try 
		{
			while(rsField.next())
			{
				String mid1 = rsField.getString(2);
				String  poolDefinition = gin.getItem(rsField.getString("pv")).toLowerCase();
				rsField.next();
				String mid2 = rsField.getString(2);
				if(!mid1.equals(mid2))
					continue;
				String tableDefinition= gin.getItem(rsField.getString("pv")).toLowerCase();
				
				if(rsField.getString("pid").equals(columnId))
					ModuleHash.put(poolDefinition,tableDefinition);
				else
					ModuleHash.put(tableDefinition,poolDefinition);
			}
			rsField.close();
		}
		catch (Exception e) 
		{
			System.out.println("Exception::Integration:: PoolConnection.java, while fetching Fields and Columns ");
			e.printStackTrace();
		}
	}
	
	/**Getting recent object values from pool table.*/
	public void generatePoolHash()
	{
		try
		{
			ResultSet rsPoolValue = dbsql.getSelect("SELECT mid, pid, pv, vt FROM " + property_details + " WHERE mid = " + recentTableObject);
			while(rsPoolValue.next())
			{
				String pid = gin.getItem(rsPoolValue.getString("pid")).toLowerCase();
				String strPvVt = rsPoolValue.getString("pv"); // It will stores the value of PV or VT.
				
				if(strPvVt.equalsIgnoreCase("0"))
				{
					strPvVt = rsPoolValue.getString("vt");
				}
				else
				{
					strPvVt = gin.getItem(strPvVt);
				}
				poolHash.put(pid, strPvVt);
			}
		}
		catch (Exception e) 
		{
			System.out.println("Exception::Integration:: PoolConnection.java, while fetching Fields Values from POOL ");
			e.printStackTrace();
		}
	}
	public Vector<Object> getPropertyVector()
	{
		boolean FLAG = false;
		Enumeration<Object> poolIte = fieldHash.keys();
		while(poolIte.hasMoreElements())
		{
			String key = poolIte.nextElement().toString();
			String value = fieldHash.get(key).toString();
			Hashtable<Object, Object> hash = new Hashtable<Object, Object>();
			hash.put("pid", key);
			hash.put("pv", value);
			propertyVect.add(hash);
			FLAG = true;
		}
		if(FLAG)
		{
			Hashtable<Object, Object> hash = new Hashtable<Object, Object>();
			hash.put("pid", "type");
			hash.put("pv", gin.getItem(tableObj));
			propertyVect.add(hash);
		}
		return propertyVect;
	}
	
	public String insertMaster()
	{
		if(propertyVect.size()!=0)
		{
			RequestParameter rqp = new RequestParameter();
			rqp.setUsername("+911234567891");
			rqp.setPassword("891");
			rqp.setProcess(process);
			rqp.setVersion("11");
			rqp.setMessage("");
			rqp.setRequest("master_table");
			rqp.setEvent(false);
			IdBean idObj = new IdBean(dbsql);
			idObj.setTable("master_table");
			idObj.execute();
			String id = idObj.getId();
			
			/** It will insert into M & PL of the POOLDB. **/
			String master = gin.getItem(tableObj)+ "_" + id;
			Master_table_Bean mtb = new Master_table_Bean();
			mtb.setDBManager(dbsql);
			mtb.setReqParam(rqp);
			mtb.setNewMasterObject(master);
			getPropertyVector();
			mtb.setPropertyVector(propertyVect);
			mtb.insert();
			return master;
		}
		return null;
	}
	
	/**
	 * @param args
	 */
	public static void main(String[] args) 
	{
		InsertMaster qrypro = new InsertMaster();
		DBManager db = new DBManager();
		db.getConnect();
		qrypro.setDatabase(db);
		
		qrypro.setRecentTableObject("8458");
		qrypro.setTableObj("8405");
		qrypro.generateProperty();
		qrypro.setFields(new Hashtable<Object, Object>());
	}

	public void setFields(Hashtable<Object, Object> fieldHash2) 
	{
		fieldHash.putAll(fieldHash2);
	}
	
	public void setPoolHash(Hashtable<Object, Object> poolHash2) 
	{
		poolHash.putAll(poolHash2);
	}
	public void setModuleHash(Hashtable<Object, Object> moduleHash2) 
	{
		ModuleHash.putAll(moduleHash2);
	}
	public Hashtable<Object, Object> getModuleHash() {
		return ModuleHash;
	}
	public Hashtable<Object, Object> getPoolHash() {
		return poolHash;
	}
	public Hashtable<Object, Object> getFieldHash() {
		return fieldHash;
	}
}